Highlighted Yellow: Implement for Project

Highlighted Green: Optional for Project

Highlighted Gray : NOT supported by Hardware

Ex: Mov R0,R1 ---- x80 %00 00 01 00  $\rightarrow$  R0zz R1zz (2 byte inst)

Mov R01,R23 --- x88 %00 01 10 11  $\rightarrow$  R0R1 R2R3 (2 byte inst)

Mov R12,\$AB47 - x89 %01 10 zz zz xAB x47 (4 byte inst)

(x89 x60 xAB x47)

## DATA MANIPULATION:

| Mov | dst, | src             | Op Co | de   | Operands Rdst1:Rdst2:Rsrc1:Rsrc2 |
|-----|------|-----------------|-------|------|----------------------------------|
| 80  | Mov  | R8,R8           | 1000  | 0000 |                                  |
| 88  | Mov  | R16,R16         | 1000  | 1000 |                                  |
| 81  | Mov  | R8,\$HH         | 1000  | 0001 |                                  |
| 89  | Mov  | R16,\$НННН      | 1000  | 1001 |                                  |
| 82  | Mov  | R8,[\$MMMM]     | 1000  | 0010 |                                  |
| 8A  | Mov  | R16,[\$MMMM]    | 1000  | 1010 |                                  |
| 83  | Mov  | [\$MMMM],R8     | 1000  | 0011 |                                  |
| 8B  | Mov  | [\$MMMM],R16    | 1000  | 1011 |                                  |
| 84  | Mov  | R8,[R16]        | 1000  | 0100 |                                  |
| 8C  | Mov  | R16,[R16]       | 1000  | 1100 |                                  |
| 85  | Mov  | [R16],R8        | 1000  | 0101 |                                  |
| 8D  | Mov  | [R16],R16       | 1000  | 1101 |                                  |
| 86  | Mov  | R8,[\$MMMM,R8]  | 1000  | 0110 |                                  |
| 8E  | Mov  | R16,[\$MMMM,R8] | 1000  | 1110 |                                  |
| 87  | Mov  | [\$MMMM,R8],R8  | 1000  | 0111 |                                  |
| 8F  | Mov  | [\$MMMM,R8],R16 | 1000  | 1111 |                                  |

Lea dst, src

\*dst MUST be a 16-bit register

LEA R16,[\$MMMM,R8]

## MATH:

10

### Addc dst,src

- Addc R8, R8
- Addc R8,\$HH 11 Ex: Addc R2,\$35 x11 %1000 0000, (x11 x80 x35)
- 12 Addc R8, [\$MMMM] Ex: Addc R1,[\$ABC8] x12 %0100 0000, (x12 x40 xAB xC8)
- 13 Addc [\$MMMM],R8
- 14 Addc R8, [R16]
- 15 Addc [R16], R8
- 16 Addc R8, [\$MMMM, R8]
- 17 Addc [\$MMMM,R8],R8

#### Subb

- 20 Subb R8,R8
- 21 Subb R8,\$HH
- 22 Subb R8, [\$MMMM]
- 23 Subb [\$MMMM],R8
- 24 Subb R8, [R16]
- 25 Subb [R16], R8
- 26 Subb R8, [\$MMMM, R8]
- 27 Subb [\$MMMM,R8], R8

#### Cmp

- 30 Cmp R8,R8
- 31 R8,\$HH Cmp
- R8,[\$MMMM] 32 Cmp
- 33 Cmp [\$MMMM],R8
- 34 R8,[R16] Cmp
- 35 [R16], R8 Cmp
- 36 R8,[\$MMMM,R8] Cmp
- 37 [\$MMMM,R8], R8 Cmp

## LOGICAL:

76

77

Xor

Xor

R8,[\$MMMM,R8]

[\$MMMM,R8], R8

#### Not 40 Ex: NOT R3 x40 %1100 0000, (x40 xC0) Not R8 [\$MMMM] 43 Not 47 [\$MMMM,R8] Not And 50 And R8,R8 R8,\$HH 51 And R8,[\$MMMM] 52 And 53 And [\$MMMM],R8 54 And R8,[R16] 55 And [R16], R8 R8,[\$MMMM,R8] 56 And 57 [\$MMMM,R8], R8 And or60 R8, R8 Or 61 Or R8,\$HH 62 Or R8,[\$MMMM] 63 [\$MMMM],R8 Or 64 R8,[R16] Or [R16], R8 65 Or R8,[\$MMMM,R8] 66 Or 67 Or [\$MMMM,R8], R8 Xor 70 Xor R8,R8 Ex: Xor R2,R1 x70 %1000 0100, (x70 x84) 71 Xor R8,\$HH 72 Xor R8,[\$MMMM] 73 Xor [\$MMMM],R8 74 Xor R8,[R16] [R16], R8 75 Xor

# STACK:

## Push

90 Push R8 Ex: Push R3 x90 %0000 1100, (x90 x0C) ;R3 is src

98 Push R16

Pop

AO Pop R8 Ex: Pop R3 xAO %1100 0000, (xAO xCO); R3 is dst

A8 Pop R16

# CONTROL:

## Unconditional:

#### Jmp

B8 jmp R16 Ex: jmp R12 xB8 %0000 0110, (xB8 x06)

BD jmp [R16]

B9 jmp \$MMMM Ex: jmp \$1234 (xB9 x12 x34)

BB jmp [\$MMMM]

#### Call

BF

C8 Call R16

jmp

CD Call [R16]

C9 Call \$MMMM

CB Call [\$MMMM]

CF Call [\$MMMM,R8]

[\$MMMM,R8]

## Ret

C0 No arguments

# CONTROL:

# Conditional:

All conditional jumps have only one addressing mode as follows:

Jcc <16-bit relative PC offset> 3 bytes total

## Signed:

| D0 | Jgt | ( N | ^ | V) | = | 0  | &&  | Z | = | 0 | «   | Z | or | ( N | ^ | V) | == | 0 | >> |
|----|-----|-----|---|----|---|----|-----|---|---|---|-----|---|----|-----|---|----|----|---|----|
| D1 | Jge |     |   | (N | ^ | V) | ) = | 0 |   |   |     |   |    |     |   |    |    |   |    |
| D2 | Jlt |     |   | (N | ^ | V) | ) = | 1 |   |   |     |   |    |     |   |    |    |   |    |
| D3 | Jle |     |   | (N | ^ | V  | ) = | 1 |   | 2 | Z = | 1 |    |     |   |    |    |   |    |

## Unsigned:

| D4 | Jhi |       | C = 0 && Z = 0                    |
|----|-----|-------|-----------------------------------|
| D5 | Jls |       | C = 1     Z = 1                   |
| D6 | Jlo | (jcs) | C = 1 Ex: jlo \$2345 (xD6 x23 x45 |
| D7 | Jhs | (jcc) | C = 0                             |
| D8 | Jeq | (jzs) | Z = 1                             |
| D9 | Jne | (jzc) | Z = 0                             |
| DA | Jmi | (jss) | S = 1                             |
| DB | Jpl | (jsc) | S = 0                             |
| DC | Jvs |       | V = 1                             |
| DD | Jvc |       | V = 0                             |

# MISCELLANEOUS:

| Ε0  | Nop |
|-----|-----|
|     |     |
| F:1 | Swi |

Rti